import Vue from 'vue'

import Cookies from 'js-cookie'

import Element from 'element-ui'
import './assets/styles/element-variables.scss'

import '@/assets/styles/index.scss' // global css
import '@/assets/styles/boom.scss' // boom css
import App from './App'
import store from './store'
import router from './router'
import permission from './directive/permission'

import './assets/icons' // icon
import './permission' // permission control
import {getDicts} from "@/api/system/dict/data";
import {getConfigKey} from "@/api/system/config";
import {
  parseTime,
  resetForm,
  addDateRange,
  selectDictLabel,
  selectDictLabels,
  download,
  handleTree,
  isEmpty,
  uuid
} from "@/utils/boom";
import Pagination from "@/components/Pagination";
// 自定义表格工具扩展
import RightToolbar from "@/components/RightToolbar"
// 滚动条
import vuescroll from 'vuescroll/dist/vuescroll-native';
import 'vuescroll/dist/vuescroll.css';
// iconPark
import {install} from '@icon-park/vue/es/all';
import '@icon-park/vue/styles/index.css';
install(Vue, 'park');

// 全局方法挂载
Vue.prototype.getDicts = getDicts
Vue.prototype.getConfigKey = getConfigKey
Vue.prototype.parseTime = parseTime
Vue.prototype.resetForm = resetForm
Vue.prototype.addDateRange = addDateRange
Vue.prototype.selectDictLabel = selectDictLabel
Vue.prototype.selectDictLabels = selectDictLabels
Vue.prototype.download = download
Vue.prototype.handleTree = handleTree
Vue.prototype.isEmpty = isEmpty
Vue.prototype.uuid = uuid()

Vue.prototype.msgSuccess = function (msg) {
  this.$message({showClose: true, message: msg, type: "success"});
}

Vue.prototype.msgError = function (msg) {
  this.$message({showClose: true, message: msg, type: "error"});
}

Vue.prototype.msgInfo = function (msg) {
  this.$message.info(msg);
}

// 全局组件挂载
Vue.component('Pagination', Pagination);
Vue.component('RightToolbar', RightToolbar);

Vue.use(permission);
Vue.use(vuescroll, {
  ops: {
    vuescroll: {
      mode: "native",  //模式:pc natice 移动端是slice
      sizeStrategy: "percent",  //父元素是否是固定的是就percent 不是就是number 填一个数值
      detectResize: true,  //内容是否根据页面调整
    },
    scrollPanel: {
      initialScrollY: false,  //初始化距离顶部的位置
      initialScrollX: false,  //初始化距离左侧的位置
      scrollingX: false,  // 是否开启横向滚动
      scrollingY: true,  //是否开启竖向滚动
      speed: 100,       //多长时间内完成一次滚动。 数值越小滚动的速度越快。
      easing: 'easeInQuad', //默认动画
      verticalNativeBarPos: "right",
      maxHeight: undefined,  //这是滚动条最大高度,内容高度小于 maxHeight 时高度自适应，超出的话出现滚动条。
      maxWidth: undefined,   //这是滚动条最大宽度,内容宽度小于 maxWidth 时高度自适应，超出的话出现滚动条。
    },
    rail: {
      background: "#e2e2e2", //轨道的背景色。
      opacity: 0.5,            //轨道的透明度。 0是透明，1是不透明
      size: "6px",             //轨道的尺寸。
      specifyBorderRadius: false, //是否指定轨道的 borderRadius， 如果不那么将会自动设置。
      gutterOfEnds: null,
      gutterOfSide: "0px",      //距离容器的距离
      keepShow: false,          //是否即使 bar 不存在的情况下也保持显示。
    },
    bar: {
      showDelay: 500,             //在鼠标离开容器后多长时间隐藏滚动条。
      onlyShowBarOnScroll: true,  //是否只在滚动时显示 bar。
      keepShow: false,            //滚动条是否保持显示。
      background: "#999999",      //滚动条背景色。
      opacity: 1,                 //滚动条透明度。
      hoverStyle: false,
      specifyBorderRadius: false,  //是否指定滚动条的 borderRadius， 如果不那么和轨道的保持一致。
      minSize: false,              //为 bar 设置一个最小尺寸, 从 0 到 1. 如 0.3, 代表 30%.
      size: "6px",                 //bar 的尺寸。
      disable: false,              //是否禁用滚动条。
    }
  },
  name: 'vue-scroll' // 自定义标签名称
});

/**
 * If you don't want to use mock-server
 * you want to use MockJs for mock api
 * you can execute: mockXHR()
 *
 * Currently MockJs will be used in the production environment,
 * please remove it before going online! ! !
 */

Vue.use(Element, {
  size: Cookies.get('size') || 'small' // set element-ui default size
});

Vue.config.productionTip = false;

new Vue({
  el: '#app',
  router,
  store,
  render: h => h(App)
});
